# THE UNITED STATES PATENT AND TRADEMARK OFFICE

In re the Application of : Kazuyuki SATO, et al.

Filed

: Concurrently herewith

For

: ROUTING APPARATUS

Serial No.

: Concurrently herewith

January 23, 2001

Assistant Commissioner of Patents Washington, D.C. 20231

# SUBMISSION OF PRIORITY DOCUMENT

S I R:

Attached herewith are Japanese patent application No. 2000-295841 of September 28, 2000 whose priority has been claimed in the present application.

Respectfully submitted

Aaron B. Karas Reg. No. 18.923

HELFGOTT & KARAS, P.C. 60th FLOOR EMPIRE STATE BUILDING NEW YORK, NY 10118 DOCKET NO.:FUSA 18.263 BHU:priority

Filed Via Express Mail Rec. No.: <u>EL522394060US</u>

On: January 23, 2001

By: Brendy Lynn Belony

Any fee due as a result of this paper, not covered by an enclosed check may be charged on Deposit Acct. No. 08-1634.

jc654 U.S. PTO 09/767302



# 日本国特許庁

PATENT OFFICE
JAPANESE GOVERNMENT

別紙添付の書類に記載されている事項は下記の出願書類に記載されて いる事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed th this Office.

出願年月日

Date of Application:

2000年 9月28日

特願2000-295841

數 **類** 人 and icant (s):

富士通株式会社

CERTIFIED COPY OF PRIORITY DOCUMENT

2000年12月 8日

特許庁長官 Commissioner, Patent Office







【書類名】

特許願

【整理番号】

0051097

【提出日】

平成12年 9月28日

【あて先】

特許庁長官殿

【国際特許分類】

H04L 12/56

【発明の名称】

ルーチング装置

【請求項の数】

5

【発明者】

【住所又は居所】

宮城県仙台市青葉区一番町3丁目3番5号 富士通東北

通信システム株式会社内

【氏名】

佐藤 和幸

【発明者】

【住所又は居所】

宮城県仙台市青葉区一番町3丁目3番5号 富士通東北

通信システム株式会社内

【氏名】

寺澤 卓也

【特許出願人】

【識別番号】

000005223

【氏名又は名称】 富士通株式会社

【代理人】

【識別番号】

100084711

【弁理士】

【氏名又は名称】

齋藤 千幹

【電話番号】

043-271-8176

【手数料の表示】

【予納台帳番号】

015222

【納付金額】

21,000円

【提出物件の目録】

【物件名】

明細書 1

【物件名】

図面 1

【物件名】

要約書 1

【包括委任状番号】 9704946

【プルーフの要否】 要

# 【書類名】 明細書

【発明の名称】 ルーチング装置

# 【特許請求の範囲】

【請求項1】 回線より到来するパケットの宛先アドレスに応じたルーチングデータを求めて該パケットに付加し、ルーチングデータに基づいてパケットをスイッチングして所定の回線に送出するルーチング装置において、

ルーチングデータ発生部を備え、要求された宛先アドレスに応じたルーチング データを発生して要求元に送出する主制御部、

回線より到来するパケットの宛先アドレスを抽出し、該宛先アドレスに応じた ルーチングデータを通知するよう主制御部に要求し、主制御部より通知されたル ーチングデータをパケットに付加して出力する回線インタフェース部、

所定の回線インタフェース部から入力する前記ルーチング要求を主制御部に送出し、主制御部からのルーチングデータを要求元の回線インタフェース部に送出し、ルーチングデータ付きパケットを該ルーチングデータに基づいてスイッチングして別の回線インタフェース部に送出するスイッチ部、

を備えたことを特徴とするルーチング装置。

【請求項2】 前記主制御部のルーチングデータ発生部は、

ルーチングデータを記憶する連想メモリ部、

宛先アドレスをキーデータとするとき、多数の宛先アドレスに応じたキーデータを記憶するキーデータ記憶部、

前記要求された宛先アドレスに応じたキーデータがキーデータ記憶部に存在するとき、該キーデータを前記連想メモリのアドレスに変換する変換部、

連想メモリ部の該アドレスよりルーチングデータを読出して要求元である回線 インタフェース部に送出するルーチングデータ送出部、

を備えたことを特徴とする請求項1記載のルーチング装置。

【請求項3】 前記主制御部は、回線速度に対応させてルーチングデータ発生部を備え、

前記回線インタフェース部は、回線より到来するパケットの宛先アドレスに応じたキーデータに回線識別子を付加して主制御部にルーチングデータを通知する

よう要求し、

主制御部は、該通知要求により回線識別子の回線速度に応じたルーチングデータ発生部よりルーチングデータを発生して要求元の回線インタフェース部に送出する、

ことを特徴とする請求項2記載のルーチング装置。

【請求項4】 前記連想メモリ部とキーデータ記憶部を1つメモリアレイの連続領域で構成し、

メモリアレイの1バイトセルの総数をy、キーデータ幅をkバイト、ルーチングデータを含む連想データ幅をrバイトとするとき、登録可能なキーデータ数および連想データ数であるエントリ数eを

e = y / (k + r)

により演算し、これらk, r, eによりキーデータおよび連想データのキーデータ領域および連想データ領域への読み/書き制御を行なう、

ことを特徴とする請求項2記載のルーチング装置。

【請求項5】 前記主制御部のルーチングデータ発生部は、更に、

前記要求された宛先アドレスに応じたキーデータと同一のキーデータ、あるいは、該宛先アドレスに応じたキーデータの非マスク部分と同一のキーデータがキーデータ記憶部に複数エントリされているとき、そのエントリ数、エントリキーデータを保持する保持部、

これらエントリ数、エントリキーデータをルーチングデータ発生部の外部のプロセッサに通知する手段、

を備えたことを特徴とする請求項2記載のルーチング装置。

【発明の詳細な説明】

[0001]

【発明の属する技術分野】

本発明はInternet, ATM network等におけるルーチング処理に際してCAM (Content Addressable Memory)を使用するルーチング装置に係わり、特に、回線より到来するパケットの宛先アドレスに応じたルーチングデータをCAMより求めてパケットに付加し、該ルーチングデータに基づいてパケットをスイッチング

して所定の回線に送出するルーチング装置に関する。

# [0002]

# 【従来の技術】

昨今のInternet/ATM networkの爆発的な普及により、ルータ(router)/ATM交換機(ATM switch)の処理速度は高速化の一途をたどっている。また、回線の高集積化によりそのルーチング/スイッチングに必要となるデータ(ルーチングデータ)を検索するためのテーブルも大容量化してきている。

ルーチングデータの検索法はCAM(Content Addressable Memory)を使用した変換処理技術により達成されている。しかし、CAMは大容量化に伴い、従来の容量のものでは多数のテーブルが必要になり、通常のLSI内部に実装することが難しくなっている。又、大容量のものは、専用の LSIとして市販されるようになっている。

# [0003]

図15は従来のルータの概略構成図であり、一般的なルータにおけるCAMを使用した検索方法の概要を説明するものである。1は主制御部(CPU)、2はスイッチ部、31~3n,41~4mは回線とスイッチ間に設けられた回線カードである。回線におけるデータ伝送はPOS(Packet over SONET,Packet over SDH)を使った伝送が一般的であり、このPOSではSDH,SONETのペイロード部にIPパケットをマッピングして伝送する。図示しない回線終端部はPOS回線よりIPパケットを分離して、回線カード31~3nに入力する。各回線カード31~3nのパケットプロセッサ3aはIPパケットの宛先アドレスを抽出し、該宛先アドレスに応じたルーチングデータをCAM 3bより取得し、該ルーチングデータをパケットに付加してスイッチ2に入力する。スイッチ2は各回線カード31~3nから入力するルーチングデータ付きパケットを該ルーチングデータに基づいてスイッチングして別の回線カード41~4mに入力する。回線カード41~4mのパケットプロセッサはルーチングデータを取り除き、しかる後、パケットをSDH,SONETフレームのペイロードにマッピングしてPOS回線に送出する。

# [0004]

図1.6はCAM 3.bをCAM LSI 3.b1と連想メモリ3.b2に分離して示す回線

カードの構成図、図17はCAM検索の流れ図である。CAM LSI 3 b<sub>1</sub>のキーデ ータ記憶部(図示せず)は多数の宛先アドレスに応じたキーデータを記憶し、又 、連想メモリ3b<sub>2</sub>はルーチングデータを記憶する。IPパケットのIPヘッダは宛 先アドレスDA(destination address=IP address)を有しているから、回線カード 3<sub>1</sub>~3nのパケットプロセッサ3aはIPパケットが入力すると(ステップ10 1)、該入ってきたIPパケットより宛先アドレスDAを抽出し(ステップ102) 、該宛先アドレスをキーデータ (key data) として、予め変換テーブルを有する CAM 3 b に転送する。 CAM 3 b の CAM LSI 3 b 1 はこのキーデータに対応 するIP addressがキーデータ記憶部に存在するかチェックし、存在すれば、該キ ーデータを前記連想メモリのアドレスに変換して連想メモリ3b<sub>2</sub>に送出する( ステップ103)。RAM構成の連想メモリ $3b_2$ は、入力したアドレスをもとにあ らかじめ設定された連想データ、例えば、スイッチングに必要となるハイウェイ 番号HW-No.(Highway No.)を出力する。パケットプロセッサ3aは、IPパケット を出力する直前に該ハイウェイ番号HW\_No.をパケットに付与してスイッチ部2に 入力し、スイッチはハイウェイ番号HW\_No.によりルーチング動作を行なう(ステ ップ104)。

# [0005]

図18は従来のルータの詳細な構成図であり、図15~図17と同一部分には同一符号を付している。主制御部1,1′は信頼性をあげるために二重化されており、同一の構成を備えている。すなわち、主制御部1,1′は、①メインプロセッサMPU 1 a,1 a′、②メインメモリMM 1 b,1 b′、③キャッシュメモリ(図示せず)、④各種I/0やCAM等のデバイスをメインプロセッサMPUに接続するためのMPU bus変換ブリッジ1 c,1 c′、⑤メインプロセッサが隣接するルータとの間で通信を行う際の出力ポート検索用CAM 1 d,1 d′、⑥スイッチ2とは別線にて各回線カード3<sub>1</sub>~3 nへ主制御部が作成したルーチングテーブルを転送するためのイーサネットスイッチングハブ(Ethernet Switching HUB) 1 e,1 e′、⑦回線カードからスイッチ経由で到来する自局宛パケットをメインプロセッサ MPUに送出するためのMPU bus変換ブリッジ1 f,1 f′などを有している。

# [0006]

回線カード3<sub>1</sub>~3nはSONET/SDH等の各種回線を収容するもので、同一の構成を備えている。ただし、回線カードが収容する各回線の速度は同一であるが、回線速度は回線カード毎に異なっている。パケットプロセッサ3aは、(1) POS回線等を介して到来するパケットの宛先アドレスDAを抽出し、該宛先アドレスDAをルーチングデータ検索用のキーデータとしてCAMへ送出したり、(2) パケットにルーチングデータ (ハイウェイ番号HW\_No.) を付与してスイッチに送出したり、(3) スイッチングされたパケットよりルーチングデータを削除して回線へ送出する。CAM 3bはCAM LSIおよび連想メモリを備え、キーデータとして入力される宛先アドレスDAよりルーチングデータ(ハイウェイ番号HW\_No.)を求めたり、その逆を実行する。LAN制御部(LANC:Lan controllor)3cはメインプロセッサMPUとの間で通信を行なってルーチングテーブルを受信する。ローカルのプロセッサMPUはLAN制御部3cの制御、回線カード内部の各種設定(Configuration)制御を行う。

スイッチ2は回線カードと主制御部1,1'間でのパケットの交換制御を行なうと共に、各回線カード間でのパケットの交換制御を行なう。

# [0007]

図19は従来のルータ装置のパケットの流れを示す説明図である。

- 1)POS回線から入力されたデータパケットは、回線カード3内の入力部分でパケットに分離される。
- 2) パケットプロセッサ3 a はパケットヘッダ内のIP宛先アドレスDAに基づいてCAM 3 b からハイウェイ番号IW-No.、その他必要な情報  $\alpha$  (QOS情報、フィルタリング情報など)を検索し、パケット(payload部分)にこれら $IW-No.+\alpha$ を付加してスイッチ 2 に転送する。
- 3) スイッチ 2 はルーチングデータHW-No.+ $\alpha$  によりパケットをスイッチングして出側の回線カード 4 に入力する。回線カード 4 のパケットプロセッサ 4  $\alpha$  はスイッチより入力するパケットからルーチングデータHW\_No.+ $\alpha$  を取り除く。
- 4) ついで、パケットプロセッサ4 a は最終的にパケットをSDH,SONETフレームのペイロードにマッピングしてPOS回線に送出する。以上により全てのルーチン

グ処理が完了する。

[0008]

図20はCAM LSIの概略内部構造図である。CAM LSI 3 b<sub>1</sub>は、アドレスデコー ダ5a、メモリアレイ5b、インデックスレジスタ5c、マスクレジスタ5d、 レスポンスレジスタ5e、プライオリティエンコーダ5fを有している。

アドレスデコーダ 5 a はアドレスデータをデコードし、別途入力するキーデータをメモリアレイの所定アドレスに格納し、あるいはメモリアレイよりキーデータを読出して出力する。メモリアレイ 5 b は多数の宛先アドレスに応じたキーデータを格納し、インデックスレジスタ 5 c は検索したいキーデータ(検索キーデータ)、すなわち、POS回線から受信したパケットの宛先アドレスに応じたキーデータを格納する。マスクレジスタ 5 d は検索キーデータのうちマスクするビット位置を指定する("1"でマスク)。レスポンスレジスタ 5 e は、(1) メモリアレイ 5 b に記憶されているキーデータと検索キーデータとのマッチング結果(比較結果)、あるいは、(2) メモリアレイ 5 b に記憶されているキーデータと検索キーデータの非マスク部分とのマッチング結果を格納する。プライオリティエンコーダ 5 f はレスポンスレジスタ 5 e のマッチング結果をもとに連想メモリ 3 b 2のアドレスを生成する。連想メモリ 3 b 2は入力するアドレスより連想データ(ルーチングデータ+α)を出力する。

[0009]

尚、図20ではキーデータを8ビットとして示しているが、説明の都合によるもので実際にはキーデータは32ビット等である。又、メモリアレイ5が8個のキーデータを記憶する場合を示しているが、メモリアレイは実際には非常に多くのキーデータを記憶する容量を有している。又、CAM内部のメモリアレイ5bは、CAM検索の用途に応じてビット幅が可変設定できるようになっており、メモリアレイの構成を変更するレジスタ(図示せず)を具備するが、連想メモリ3b2については、ハードウェア設計時に連想用アドレスと連想データのビット幅が固定される。

[0010]

【発明が解決しようとする課題】

従来のCAMを用いたルーチング装置(ルータ)では、下記の問題がある。

#### 1) CAM LSIのハイコスト

昨今のInternetの普及により、CAMのエントリ数が増加の一途をたどっている。CAM LSI一個当りで処理できるエントリ数は、1エントリ当り36ビット必要とすると、せいぜい64k個程度である。ここで36ビットは、IP\_v4(IP-version 4)における宛先アドレスとして必要な32ビットと制御ビットとしての4ビットの合計である。

# [0011]

# 2) CAM LSIの高い実装面占有率

上記のようにCAM LSI(4×4cm程度)として15個搭載する必要があるとすると、 実装面占有率が高くなる。このため、回路カードを二階建て等の複雑な構造にし なければならなくなる。

# 3) ルーチングテーブルの転送時間

ルーチングテーブルを一元管理する主制御部のメインプロセッサから各回線カードへルーチングテーブルを転送する必要がある。例えば、システム立ち上げの際、各回線カード内に実装しているCAM へ主制御部のメインプロセッサからルーチングテーブルを転送する必要がある。このため、システム立ち上げに相当の時間がかかり、しかも、障害発生時のリカバリーにも時間がかかる。

#### [0012]

# 4) 連想データのビット幅変更

CAMは、CAM LSIにRAM構成の連想メモリを外付けする構成になっている。このため、キーデータがIP\_v4→IP\_v6(4バイト→16バイト)等へ変更になると、ハードウェアの回路構成を変更する必要が発生し、新規回線カードを設計しなおさなければならない。

#### 5) キーデータのマルチプルヒット (Multiple hit)

従来のCAMは統計処理機能がないため、検索キーデータに複数のエントリキーデータがヒットするマルチプルヒット(Multiple hit)時に統計処理を実行できない。このため、主制御部のメインプロセッサMPUがメインメモリMM上でプログラム処理により統計情報を計算する必要がある。この統計処理はメインプロセッ

サに対し髙負荷となる。

#### [0013]

### 6) 回線速度とCAMの関係

従来のルータは回線カードにCAMを実装し、かつ、回線カードには同一速度の複数の回線を収容する(例えば、OC-12回線×4を搭載する)。このようにする理由は、回線カードに速度が異なる回線を収容する構成では、全ての回線カードに最高速度の高価なCAMを必要とし、コストアップになるからである。しかし、回線カード毎に同一速度の回線を収容する従来構成のルータでは、各回線速度に応じた回線カードを用意する必要が有り、ネットワークによっては使用しない回線カードが発生したり、回線カードに収容する回線数が少ない場合が発生する。すなわち、従来のルーチング装置は回線カードの回線収容効率が悪く、コストアップになっている。

# [0014]

以上から本発明の目的は、安価で、かつ、コンパクトなルーチング装置を提供 することである。

本発明の別の目的は、使用するCAMの個数を削減してルーチング装置のコストダウンと実装効率を高めることである。

本発明の別の目的は、障害が発生しても運用継続可能にしてルーチング装置の信頼性を向上することである。

本発明の別の目的は、CAM周辺の回路を設計変更しなくてもCAMにおける 連想データやキーデータのビット幅を可変制御できるルーチング装置を提供する ことである。

本発明の別の目的は、マルチプルヒット時の処理をCAM LSI内部にて実現できるようにしてメインプロセッサの統計処理を少なくし、該メインプロセッサの負荷を軽減することである。

本発明の別の目的は、速度の異なるCAMを回線速度毎に使い分けれるようにし、かつ、回線カードに種々の回線速度の回線を収容できるようにして、ルーチング装置のコストダウンを図ることである。

本発明の別の目的は、電源投入時やリカバリー時におけるシステム立ち上げ時

間を減少できるルーチング装置を提供することである。

#### [0015]

#### 【課題を解決するための手段】

本発明は、回線より到来するパケットの宛先アドレスに応じたルーチングデータを求めて該パケットに付加し、ルーチングデータに基づいてパケットをスイッチングして所定の回線に送出するルーチング装置であり、(1) ルーチングデータ発生部を備え、要求された宛先アドレスに応じたルーチングデータを発生して要求元に送出する主制御部、(2) 回線より到来するパケットの宛先アドレスを抽出し、該宛先アドレスに応じたルーチングデータを通知するよう主制御部に要求し、主制御部より通知されたルーチングデータをパケットに付加して出力する回線インタフェース部、(3) 所定の回線インタフェース部から入力する前記ルーチングデータ要求を主制御部に送出し、主制御部からのルーチングデータを要求元の回線インタフェース部に送出し、ルーチングデータ付きパケットを該ルーチングデータに基づいてスイッチングして別の回線インタフェース部に送出するスイッチ部、を備えている。

#### [0016]

主制御部のルーチングデータ発生部は、(1) ルーチングデータを記憶する連想メモリ部、(2) 宛先アドレスをキーデータとするとき、多数の宛先アドレスに応じたキーデータを記憶するキーデータ記憶部、(3) 前記要求された宛先アドレスに応じたキーデータがキーデータ記憶部に存在するとき、該キーデータを前記連想メモリのアドレスに変換する変換部、(4) 連想メモリ部の該アドレスよりルーチングデータを読出して要求元である回線インタフェース部に送出するルーチングデータ送出部、を有している。

本発明のルーチング装置は、従来、個々の回線カードと主制御部の両方に配置していたCAM(ルーチングデータ発生部)を主制御部側に集約してルーチングテーブルを一元管理する。これにより、システム全体で使用しているCAMの個数を削減でき、コストダウンと実装効率を向上することができる。

又、CAMを主制御部にのみ持たせるだけでよいため、システム立ち上げの際 、主制御部のメインプロセッサから回線カードにルーチングテーブルを転送する

必要がなく、電源投入時やリカバリー時における立ちシステム上げ時間を減少することができる。

#### [0017]

本発明のルーチング装置は、主制御部に各回線速度に対応させてルーチングデータ発生部(CAM)をそれぞれ備える。主制御部は、回線インタフェース部から回線識別子付きのルーチングデータ要求があったとき、回線速度に応じたCAMからルーチングデータを求めて要求元の回線インタフェース部に送出する。このようにすれば速度の異なるCAMを回線速度毎に使い分けることが可能となり、しかも、回線カードに種々の速度の回線を収容することが可能となり、安価で低速のCAMを使用でき、しかも、回線カードの回線収容効率を向上できるためルーチング装置のコストダウンを図ることができる。

本発明のルーチング装置は、主制御部を二重化する。運用中の主制御部は配下の各CAMの記憶内容(ルーチングテーブル)を更新するとき、スタンバイ中の主制御部の各CAMのルーチングテーブルも更新し、運用中の主制御部側に障害が発生したとき、スタンバイ中の制御部は新たに運用中制御部としてルーチング制御を継続する。このようにすれば、CAMをメインプロセッサへ集約した場合の障害発生時の信頼性を向上させることができる。

#### [0018]

本発明のルーチング装置は、連想メモリ部とキーデータ記憶部を1つのメモリアレイで構成し、該メモリアレイの連続する2つの領域をそれぞれ連想メモリ部、キーデータ記憶部とする。メモリアレイに対するアクセス部は、メモリアレイの1バイトセルの総数をy、キーデータ幅をkバイト、ルーチングデータを含む連想データ幅をrバイトとするとき、登録可能なキーデータ数および連想データ数であるエントリ数eを次式

#### e = y / (k + r)

により演算し、これらk, r, eによりキーデータおよび連想データのメモリアレイへの読み/書き制御を行なう。このようにすれば、CAM周辺の回路を設計変更しなくても、y, k, rをプログラマブルに変更するだけで連想データやキーデータのビット幅を可変制御できる。

本発明のルーチング装置は、主制御部のルーチングデータ発生部にマルチプル ヒットしたエントリ数、エントリキーデータの管理を行なわせる。このようにす れば、マルチプルヒット時の処理をCAM LSI内部にて実現でき、メインプロセッ サの統計処理を少なくして負荷を軽減することができる。

# [0019]

# 【発明の実施の形態】

#### (A)システム構成

図1は本発明のルーチング装置のシステム構成図であり、11、11 は信頼性をあげるために二重化された同一構成の主制御部(0系、1系の主制御部)、12はスイッチ部、13 $_1$ ~13 $_1$ 0kSONET/SDH、Ethernet等の各種回線を収容する回線カード(回線インタフェース部)である。

主制御部11,11'は、①メインプロセッサMPU 11a,11a'、②メインメモリMM 11b,11b'、③システムバスに接続された各種I/0やCAM等のデバイスをメインプロセッサMPUに接続するためのMPUバス変換ブリッジ11c,11c'、④他系のCAMとの通信を行うためのクロスコネクト部11d,11d'、⑤回線速度対応に設けられ、回線速度によって選択可能な複数個のCAM11e<sub>1</sub>~11en,11e<sub>1</sub>'~11en'、⑥各回線カードからスイッチ経由で到来する自局宛データを取り込んでシステムバスに送出するバス変換ブリッジ11f,11f'などを有している。各回線カードやメインプロセッサMPUからCAMへのアクセスはすべてシステムバス11g,11g'を介して行われる。尚、11h、11h'はMPUバスである。

#### [0020]

CAM11e $_1$ ~11e $_1$ , 11e $_1$ , ~11e $_1$ , ~12e $_1$ , ~11e $_1$ , ~11e $_1$ , ~11e $_1$ , ~12e $_1$ , ~12e $_1$ , ~11e $_1$ , ~12e $_1$ , ~12e

 $1 e_1$   $^\prime \sim 1 1 e_1$  はブロック的に同一構成を備えているが、製造プロセスによりアクセス速度が異なり、サフィックス番号が大きくなる程、高速アクセス可能になっている。

#### [0021]

回線カード13<sub>1</sub>~13nは、パケットプロセッサ13a、回線カード内部の各種設定(Configuration)を行うマイクロプロセッサMPU 13bを備えている。パケットプロセッサ13aは、(1)各回線より到来するパケットの宛先アドレスDAを抽出し、該宛先アドレスDAをルーチングデータ検索用のキーデータ(検索キーデータ)としてスイッチ12を介して主制御部11,11′のCAMへ送出したり、(2)主制御部11,11′よりスイッチ12を介して取得したルーチングデータ(ハイウェイ番号HW\_No.)をパケットに付与してスイッチに送出したり、(3)スイッチングされて入力するパケットよりルーチングデータを削除して回線へ送出する機能を有している。尚、パケットプロセッサ13aは、スイッチが検索キーデータであるか、パケットであるかを識別できるようにするために、検索キーデータにキーフラグを付加し、パケットにはデータフラグを付加してスイッチ12に送出する。

スイッチ12は、(1) 所定の回線カード13<sub>1</sub>~13nから入力するキーフラグ付きの検索キーデータを主制御部11に送出し、(2) 主制御部11のCAMより求めたルーチングデータを要求元の回線カードに送出し、又、(3) データフラグ付きのパケットをルーチングデータに基づいてスイッチングして別の回線インタフェース部に送出する。

#### [0022]

図1のルーチング装置は、以下の特徴を有している。

# 1) CAM 実装位置

従来個々の回線カードと主制御部の両方に配置していた各CAMを主制御部11側に集約し、ルーチングデータ要求、検索されたルーチングデータの送受を、パケットプロセッサ13aとスイッチ12のパスを経由するin-band方式により行なう。また、ルーチングテーブル(キーデータ/連想データ)を主制御部11のCAMで一元管理し、従来各回線カードで重複管理していたキーデータを削減

する。これにより、システム全体で使用しているCAMの個数を削減でき、コストダウンと実装効率の向上を図ることができる。又、CAMを主制御部11にの み持たせるだけでよいため、電源投入時やリカバリー時におけるシステム立ち上 げ時間を減少できる。

# [0023]

# 2) CAM LSIの二重化構成

CAMを主制御部11へ集約した場合の障害発生時の信頼性を向上させるために主制御部を二重化し、0系/1系の主制御部11,11'間にCAM専用のクロスコネクトパス14を設け、該クロスコネクトバスを介して両系のCAMが保持するルーチングテーブルを一致させ、運用系のCAMが障害になったときスタンバイ系のCAMにてリカバリーを可能とする。

#### [0024]

#### 3) 回線速度対応CAMの導入

CAMはlatency (待ち時間)が小さい程、換言すればアクセス時間が短い程高価となる。このため、高速対応の単一品種のCAMだけを使用する構成ではコストアップになる。本発明のルーチング装置は、回線速度対応に複数個のCAM11e<sub>1</sub>~11enを主制御部11に設け、回線速度によって使用するCAMを使い分ける。これにより、CAMの数、CAMの種類を最適化して、CAM資源の有効活用を図り、ルータのコストをさげる。

#### [0025]

通常、回線単位でCAM検索に必要となる最低時間はパケット送信時間である。すなわち、1 パケット送信中にCAM検索を終わらせる必要があり、回線速度が高速で、転送データ数が短い程その時間は厳しくなっていく。図2(A),(B)はPOS回線のCAM検索最低時間の例を示す図表であり、(A)はOC-12Cの場合、(B)はOC-192Cの場合である。

0C-12Cの1ビット当りの転送時間は1.6nsであるから、トータルの転送時間は1.6×(IPデータ変動分 n + PPP+IPヘッダ固定分)

となり、 $IPデータ変動分を1 \sim 1500$ バイトとすると、転送時間0.36ns $\sim 19.64$ nsとなる。一方0C-192Cの場合には、1ビット当りの転送時間は0.1nsであるから、

# トータルの転送時間は

0.1×(IPデータ変動分 n + PPP+IPへッダ固定分)

となり、IPデータ変動分を1~1500バイトとすると、転送時間0.02ns~1.23nsとなる。1パケット送信中にCAM検索を終わらせる必要があるため、回線速度が 高速であれば高価な高速アクセス可能なCAMを使用し、回線速度が低速であれば安価な低速アクセスのCAMを用いる。

# [0026]

(B) パケットプロセッサとCAM間の送受信処理

図3は回線カードが連想データ(ルーチングデータ)を取得するための、パケットプロセッサとCAM間の送受信処理フロー、図4はパケットプロセッサとCAM間の送受信データのデータフォーマット、図5はパケットプロセッサとCAM間の送受信データタイムチャートである。

回線カード13のパケットプロセッサ13 a は回線から受信したIPパケットのIPヘッダより宛先アドレスDAを検索し、該宛先アドレスDAを検索キーデータ51 (図4(A)参照)として抽出する(ステップ201)。ついで、パケットプロセッサ13 a は、スイッチ12が検索キーデータであると認識できるようにするために該検索キーデータ51にキーフラグ52を付加すると共に、主制御部が回線速度を識別できるようにIPパケットが到来した回線の識別子(Line ID)53を付与し(ステップ202)、検索キーデータをスイッチ12に入力する(ステップ203)。

# [0027]

スイッチ12は受信した転送データの先頭ビット(フラグ)を参照し(ステップ204)、先頭ビットがデータフラグであれば転送データはパケットであると判定し、ルーチングデータに基づいてパケットを所定の回線カードにスイッチングする(ステップ205)。

受信した転送データの先頭ビットがキーフラグであれば、スイッチ12は0系、1系の主制御部11,11′のいずれが運用中であるか判断し(ステップ206)、運用中の主制御部にフラグを削除して回線識別子53と検索キーデータ51を送出する。例えば、0系の主制御部11が運用中であるとすれば、スイッチ

12はフラグを削除して(回線識別子+検索キーデータ)を主制御部11のバスブリッジ11fに送出する。尚、スイッチが二重化されている場合には、スイッチ12は転送元スイッチを特定するスイッチ識別子SW ID54をキーデータに付加する。

バスブリッジ11fは、受信データに送り先(クロスコネクト部)のバスアドレス55を付与してシステムバス11gを介してクロスコネクト部11dへ転送する(ステップ207)。

#### [0028]

クロスコネクト部11dは受信データより検索キーデータ51、回線識別子53を分離し(ステップ208)、回線識別子53から使用するCAMをデコードし、該当CAMが存在するか判別する(ステップ209)。すなわち、回線識別子53に基づいて回線速度を求め、該回線速度に応じたCAMを求め、該CAMが主制御部11に実装されているかチェックする。該当CAMが主制御部11に実装されていなければエラー処理し(ステップ210)、実装されていれば該当CAMをアクセス可能にイネーブルする(ステップ211)。ついで、クロスコネクト部11dは検索キーデータ51を該当CAM 11eに転送する(ステップ212)。該当CAM 11eは検索キーデータ51に基づいて連想データ(ルーチングデータ)56を検索し(ステップ213)、該連想データ(Associate Data)をクロスコネクト部11dに返す。

# [0029]

クロックコネクタ部11dは、連想データ56に元の回線識別子53、スイッチ識別子54を付加すると共に送り先(バスブリッジ11f)のバスアドレス57を付与してシステムバス11gに送出する。バスブリッジ11fはクロスコネクト部11dから受信したデータよりバスアドレス56、スイッチ識別子54を削除し、スイッチ識別子が示すスイッチ12に(回線識別子53+連想データ56)を入力する。スイッチ12は回線識別子53を削除し、連想データ56を所定回線カードのパケットプロセッサ13aに入力する(ステップ214)。

以上はステップ206において、0系の主制御部11が運用中であるとした場合である。しかし、1系の主制御部11′が運用中であるとすれば、1系主制御

部11'はステップ217~224において0系主制御部11のステップ207~214と同様の処理を実行する。

# [0030]

# (b) 通常パケットのスイッチング

パケットプロセッサ13 a は連想データを受信すれば、ルーチングデータ(ハイウェイ番号HW No.)、その他の情報αを取り出し、これら情報(HW No.+α)61をIPパケット(ペイロード)62に付加してスイッチ12に入力する(図4(B)参照)。尚、先頭の1bitに一連の転送データがスイッチングすべき通常パケットであることを示すデータフラグ(Data Flag)63を付与する(以上、ステップ202,203)。

スイッチ12は受信した転送データの先頭ビット(フラグ)を参照し(ステップ204)、先頭ビットがデータフラグであれば転送データはパケットであると判定し、フラグを除去し、ルーチングデータ61に基づいてパケットを所定の回線カードにスイッチングする(ステップ205)。該回線カードはスイッチ12よりパケットを受信すれば、ルーチングデータを削除し、SONET/SDHのペイロードにマッピングして回線へ送出する。

# [0031]

図5のタイムチャートは横軸に時間をとったものである。本発明のルーチング 装置は、スイッチ12、システムバス11gを経由するインバンド方式によりC AMへアクセスする。このため、ルーチングデータを得るのに多少の時間を必要 とする。しかし、システムバスの速度向上、スイッチの動作速度向上により、実 際のアクセス時間を短くすることができ、従来型ルーチング装置のアクセス時間 と遜色なく動作可能である。

# [0032]

#### (C)回線カードの異種回線の混在搭載

図1では各回線カード13<sub>1</sub>~13nは同一構成であることを想定して説明したが、回線カードは複数のパケットプロセッサを備えていてもよく、又、収容する回線の速度は任意でよい。図6は異種回線の混在搭載を説明する説明図であり、回線カード13<sub>1</sub>には1つのパケットプロセッサ13aと1つのMPU 13bが搭

載され、4種類の速度の異なる回線0C-3, 0C-12, 0C-48, 0C-192が収容されている。回線カード $13_2$ には、2つのパケットプロセッサ $13a_1$ ,  $13a_2$ と1つのMPU 13 bが搭載され、4種類の速度の異なる回線0C-3, 0C-12, 100BT、Gi-etherが収容されている。回線カード13nには、4つの同一回線0C-12が搭載されている。

# [0033]

# [0034]

# (D) CAM周辺の構成

図7はCAM周辺の回路構成図であり、図1と同一部分には同一符号を付している。クロスコネクト部11d内のバスコントローラ31は、システムバス11gと連想データバス(Associate Data Bus)32、キーデータバス(Key Data Bus)23間のバス調停制御を行う。連想データバス32は、クロスコネクト部内に設けられ、CAM 11e<sub>1</sub>~11enを構成する連想メモリ21(図1参照)から読出された連想データ等を伝送する。キーデータバス33は、クロスコネクト部内に設けられ、CAMを構成するキーデータに簡部22や連想メモリ21に書き込むキーデータ/連想データやルーチングデータ検索用のキーデータ(検索キーデータ)等を伝送する。すなわち、バスコントローラ31は、メインプロセッサ11aからシステムバス11gを介して入力するルーチングテーブル(キーデータ/連想データ)をキーデータバス33に送出し、所定のCAMに書き込む。又、ルーチングデータ検索時に、回線カードからシステムバス11gを介して入力する検索キーデータをキーデータバス33に送出する。又、CAMから読出さ

れた連想データ等を連想データバス32を介してシステムバス11gに送出する

# [0035]

CAMセレクタ34は、回線カード13<sub>1</sub>~13nからインバンド方式で受信するデータより、①キーデータ51、②回線識別子(Line ID)53、③スイッチ識別子(SW ID)の分離を行い、キーデータをCAMへ送出すると共に回線識別子、スイッチ識別子を保持し、後述のラインセレクタ35に入力する。又、CAMセレクタ34は、回線識別子53からアクセスすべきCAMを選択し、そのCAMに対し制御線を介してアクセスイネーブル信号ACENを送出する。図8はルーチングデータ検索時におけるCAMアクセスのタイムチャートである。CAMセレクタ34は、クロックに同期してアクセスイネーブル信号ACENをハイレベルにし、しかる後、キーデータKDTをクロックに同期してCAMに送出する。

ラインセレクタ35は、CAMより検索した連想データ (Associate Data)に CAMセレクタ34から入力する回線識別子53、スイッチ識別子54を付与し て連想データバス32に送出する。

#### [0036]

バスコントローラ36は、クロスコネクトバス14と連想データバス32、キーデータバス23間のバス調停制御を行う。運用系の主制御部11のメインプロセッサ11aは、内部のCAM 11 $e_1$ ~11enのルーチングテーブルを更新するとき、あるいは、これらCAM 11 $e_1$ ~11enに新たにルーチングテーブルを書き込むとき、スタンバイ系の主制御部11′内のCAM 11 $e_1$ ′~1en′にもルーチングテーブルの更新、書き込みを行なう。かかる場合、バスコントローラ36はバス調停制御を行ってメインプロセッサ11aからのルーチングテーブルをクロスコネクトバス14を介してスタンバイ系主制御部11′に送出する。

# [0037]

# (E) CAMの内部構成

図9はCAMの内部構成図であり、図1と同一部分には同一符号を付している。 I/O制御部20はキーデータと連想データの入出力制御を行うもので、クロ

スコネクト部側から各種データ(キーデータ/連想データ/検索キーデータ)、 制御信号、イネーブル信号が入力し、又、クロスコネクト部側へ連想データ/マ ルチプルヒット関連データ等を出力する。

連想メモリ部21は連想データ(ルーチングデータHW-No.+α)を記憶し、キーデータ記憶部22は宛先アドレスをキーデータとするとき、多数の宛先アドレスに応じたキーデータを記憶する。連想メモリ21とキーデータ記憶部22は1つメモリアレイの連続領域で構成され、プログラマブルに連想データのビット幅rやキーデータのビット幅k、領域境界線を可変に設定できるようになっている。【0038】

アドレス変換部23は各回線カードから要求された宛先アドレスDAに応じたキーデータ(検索キーデータ)がキーデータ記憶部22に存在するとき、キーデータを連想メモリ21のアドレスに変換するもので、レスポンスレジスタ23a、プライオリティエンコーダ23bを備えている。レスポンスレジスタ23aは、

(1) キーデータ記憶部 2 2 に記憶されている円とキーデータと検索キーデータとのマッチング結果(比較結果)、あるいは、(2) キーデータ記憶部 2 2 に記憶されているエントリキーデータと検索キーデータの非マスク部分とのマッチング結果を格納する。プライオリティエンコーダ 2 3 bはレスポンスレジスタ 2 3 a のマッチング結果をもとに連想メモリ 2 1 のアドレスを生成し、連想メモリ 2 1 の該アドレスより連想データ(ルーチングデータHW-No.+α)を出力する。キーデータ記憶部 2 2 に記憶されている複数のキーデータが検索キーデータと一致する場合(マルチプルヒット)、プライオリティエンコーダ 2 3 b は予め定められている基準に基づいて定まる 1 つのエントリキーデータに応じたアドレスを発生する。このアドレスから読出した連想データによりパケットを送ってみて、パケットが宛先に届かなければ要求により次のエントリキーデータに応じたアドレスを出力し、以後同様にシーケンシャルにアドレスを出力する。

#### [0039]

メモリアクセス部24は、メモリアレイへのキーデータ/連想データの書き込み制御、検索キーデータに応じた連想データの読出し制御をするもので、アドレスデコーダ24a、インデックス/マスクレジスタ24b、モード設定レジスタ

24cを備えている。アドレスデコーダ24aは入力するアドレスデータをデコードしてメモリアレイの所定のアドレスにキーデータ/連想データを書き込み(ルーチングテーブル更新時)、あるいはメモリアレイの所定ドレスよりキーデータ/連想データを読み出す(ルーチングデータ検索時)。インデックス/マスクレジスタ24bは検索キーデータおよびマスクデータを記憶する。モード設定レジスタ24cはキーデータのビット幅k/連想データのビット幅r/エントリ数eを保持するもので、エントリ数eはメモリアレイに保存可能なキーデータ数(=連想データ数)である。アドレスデコーダ24aはk,r,eに基づいてアドレスデータに応じたキーデータ領域22および連想データ領域21におけるアドレスを発生してキーデータ領域22および連想データ領域21におけるアドレスを発生してキーデータおよび連想データの読み/書き制御を行なう。このように、従来、CAM LSI外部に配置していたRAM構成の連想メモリをCAM LSI内部に配置することによりメモリアレイを有効に活用することが可能になり、又、キーデータ幅や連想データ幅が変更になってもモード設定レジスタ24cの設定データのみの変更により対応することができる。

#### [0040]

マルチプルヒット管理部25は、キーデータ記憶部22に記憶されている複数のキーデータが検索キーデータと一致する時(マルチプルヒット時)、ヒット数 CHをヒットレジスタ25aに格納すると共に、検索キーデータとマッチングするエントリキーデータをキーデータレジスタ25に格納し、適宜、ヒット数CH およびエントリキーデータの組をI/Oコントローラ20を介してメインプロセッサ11aに送出する。以上のように、マルチプルヒット管理部25がヒット数およびエントリキーデータを管理するため、メインプロセッサ11aは必要に応じてこれら管理データを読みとって所定の処理を行なうだけでよいため、マルチプルヒット時におけるメインプロセッサの処理を軽減することができる。尚、メインプロセッサの処理としては、キーデータ記憶部22に記憶されているキーデータの誤り検出処理等がある。

# [0041]

(F) メモリアレイおよび周辺回路

図10はメモリアレイお及びその周辺回路の構成図であり、図9と同一部分に

は同一符号を付している。RAM構成のメモリアレイMCAの前半はキーデータ記憶領域22、後半が連想メモリ領域21になっている。メモリアレイMCAの1バイトセルの総数をy、キーデータ幅をkバイト、ルーチングデータを含む連想データ幅をrバイトとするとき、メモリアレイに登録可能なキーデータおよび連想データの数(エントリ数)eは、キーデータ数と連想データ数が同じであるから次式

$$e = y/(k+r) \qquad (1)$$

により求まり、これら k, r, e はモード設定レジスタ24 c に設定される。エントリ数 e は例えば I / O コントローラ20 (図9) が演算してモード設定レジスタ24 c に設定する。図11はメモリアレイにおける1バイトセル数 y、キーデータ幅 k、連想データ幅 r、エントリ数 e の関係図表であり、エントリ数は(1)式により求まる。図11の図表において、左欄はメモリアレイのセルバイト数が1000、右欄はセルバイト数が16,384の場合における y, k, r, e の関係を示している。

#### [0042]

キーデータ記憶領域22の第iキーデータアドレスに対応するセルバイトアドレスはこれらk, r, eより、以下

$$i \cdot k \sim i \cdot k + (k-1)$$
 (2)

で与えられる。又、連想メモリ領域21の第j連想データアドレスに対応するセルバイトアドレスは以下

$$k \cdot e + j \cdot r \sim k \cdot e + j \cdot r + (r - 1)$$
 (3)

で与えられる。アドレスデコーダ 2 4 a はモード設定部 2 4 c に設定された k, r, e を参照し、(2),(3)式により入力するアドレスデータをメモリアレイMC Aのバイトアドレスに変換する。

#### [0043]

#### ・キーデータの書き込み

メモリアレイMCAに対すキーデータ書き込みに際して、キーデータがメモリアレイMCAに入力し、キーデータの書き込みアドレスiがアドレスデコーダ24aに入力すると、アドレスデコーダ24aはアドレスデータiを(2)式に従っ

てデコードし、デコードにより求まるバイトアドレスが示すk個の1バイトセル にキーデータを書き込む。以後、同様に順次キーデータをメモリアレイMCAの キーデータ記憶領域22に書き込む。

# ・連想データの書き込み

メモリアレイMCAに対する連想データの書き込みに際して、連想データがメモリアレイMCAに入力し、連想データの書き込みアドレスjがアドレスデコーダ24aに入力すると、アドレスデコーダ24aはアドレスデータjを(3)式に従ってデコードし、デコードにより求まるバイトアドレスが示すr個の1バイトセルに連想データを書き込む。以後、同様に順次連想データをメモリアレイMCAの連想メモリ領域21に書き込む。

#### [0044]

・検索キーデータに応じた連想データの読出し

検索キーデータに応じた連想データを出力するには、該検索キーデータをイン デックス/マスクレジスタ24bに入力して記憶すると共に、アドレスデコーダ 24 a にキーデータの読出しアドレスi=1~e を順次入力する。アドレスデコ ーダ24aはアドレスデータiを(2)式に従ってデコードし、デコードされたバ イトアドレスが示すk個のバイトセルからkバイトのキーデータ(エントリキー データ)を読み出し、ゲート26を介してインデックス/マスクレジスタ24b に入力する。インデックス/マスクレジスタ24bはその比較機能により、検索 キーデータとエントリキーデータを比較し、比較結果をレスポンスレジスタ23 aに格納する。以後、同様に、アドレスデータiを歩進し、i=1~eが示すキ ーデータアドレスから読み取ったエントリキーデータと検索キーデータとの比較 結果をレスポンスレジスタ23aに格納する。比較処理が終了すれば、プライオ リティエンコーダ23bは検索キーデータと一致したエントリキーデータを連想 メモリ領域21のアドレスjに変換し、アドレスデコーダ24aに入力する。ア ドレスデコーダ24 a は入力する連想データアドレスjを(3)式に従ってデコー ドし、デコードにより得られたバイトアドレスの示すァ個のバイトセルからァバ イトの連想データを読出し、ゲート26を介して出力する。

以上のように、本発明のルーチング装置によれば、連想データやキーデータの

ビット幅を変更する際、変更後の連想データのビット幅rやキーデータのビット幅kを入力するだけでよく、CAM周辺回路の設計変更をする必要がない。

# [0045]

- (G) 各ユニット間のデータの流れ
- (a) CAM-メインプロセッサ間のデータの流れ

# [0046]

(b) CAM-パケットプロセッサ間のデータの流れ

図13はCAM-パケットプロセッサ間のデータの流れを説明する説明図である。運用系のCAMと回線カードのパケットプロセッサ間のデータ送受はルート R1~R3を介して行なわれる。ルートR1は回線カード13 $_1$ が検索キーデータを運用系のCAM11e $_1$ へ与えて検索結果(ルーチングデータ)を受信する場合のルートである。ルートR2は回線カード13 $_2$ が検索キーデータを運用系の CAM11e $_1$ へ与えて検索結果(ルーチングデータ)を受信する場合のルートである。ルートR3は主制御部11′が運用系になった場合、回線カード13 $_1$ が検索キーデータを運用系のCAM11e $_1$ 1′へ与えて検索結果(ルーチングデータ)を受信する場合のルートである。

# [0047]

(c) 障害時のCAM-パケットプロセッサ間のデータの流れ

図14は障害時のCAM-パケットプロセッサ間のデータの流れを説明する説明図である。障害発生前は、回線カード13 $_1$ のパケットプロセッサ13 a はルートR1を介して運用系主制御部11のCAM 11e $_1$ ~11enにアクセスしてルーチングデータを取得する。しかし、CAM 11e $_1$ ~11enに障害が発生して主制御部11'が運用系になれば、パケットプロセッサ13 a はルートR2を介して運用系の主制御部11'のCAM 11e $_1$ '~11en'にアクセスしてルーチングデータを取得する。

# [0048]

#### ・付記

(付記1) 回線より到来するパケットの宛先アドレスに応じたルーチング データを求めてパケットに付加し、該ルーチングデータに基づいてパケットをス イッチングして所定の回線に送出するルーチング装置において、

ルーチングデータ発生部を備え、要求された宛先アドレスに応じたルーチング データを発生して要求元に送出する主制御部、

回線より到来するパケットの宛先アドレスを抽出し、該宛先アドレスに応じた ルーチングデータを通知するよう主制御部に要求し、主制御部より通知されたル ーチングデータをパケットに付加して出力する回線インタフェース部、

所定の回線インタフェース部から入力する前記ルーチングデータ要求を主制御部に送出し、主制御部からのルーチングデータを要求元の回線インタフェース部に送出し、ルーチングデータ付きパケットを該ルーチングデータに基づいてスイッチングして別の回線インタフェース部に送出するスイッチ部、

を備えたことを特徴とするルーチング装置。

#### [0049]

(付記2) 前記主制御部のルーチングデータ発生部は、

ルーチングデータを記憶する連想メモリ部、

宛先アドレスをキーデータとするとき、多数の宛先アドレスに応じたキーデータを記憶するキーデータ記憶部、

前記要求された宛先アドレスに応じたキーデータがキーデータ記憶部に存在するとき、該キーデータを前記連想メモリのアドレスに変換する変換部、

連想メモリ部の該アドレスよりルーチングデータを読出して要求元である回線 インタフェース部に送出するルーチングデータ送出部、

を備えたことを特徴とする付記1記載のルーチング装置。

(付記3) 前記主制御部を二重化し、運用中の主制御部は前記各記憶部の記憶内容を更新するとき、スタンバイ中の主制御部の各記憶部の記憶内容も更新し、運用中の主制御部側に障害が発生したとき、スタンバイ中の制御部は新たに運用中制御部としてルーチング制御を継続する、

ことを特徴とする付記2記載ルーチング装置。

#### [0050]

(付記4)前記主制御部は、回線速度に対応させてルーチングデータ発生部を備え、

前記回線インタフェース部は、回線より到来するパケットの宛先アドレスに応じたキーデータに回線識別子を付加して主制御部にルーチングデータを通知するよう要求し、

主制御部は、該通知要求により回線識別子の回線速度に応じたルーチングデータ発生部よりルーチングデータを発生して要求元の回線インタフェース部に送出する、

ことを特徴とする付記2記載のルーチング装置。

#### [0051]

(付記5) 回線インタフェース部に任意の回線速度の回線を接続する、 ことを特徴とする付記4記載のルーチング装置。

(付記6) 各回線インタフェース部は、主制御部へ送出するルーチングデータ要求にキーフラグを付し、パケットにデータフラグを付してスイッチ部に入力し、

スイッチ部はキーフラグ付きデータを主制御部に送出し、データフラグ付きパケットをルーチングデータに基づいて出力側の回線インタフェース部に送出する

ことを特徴とする付記2記載のルーチング装置。

[0052]

(付記7) 前記連想メモリ部とキーデータ記憶部を1つメモリアレイの連続領域で構成し、

メモリアレイの1バイトセルの総数をy、キーデータ幅をkバイト、ルーチングデータを含む連想データ幅をrバイトとするとき、登録可能なキーデータ数および連想データ数であるエントリ数eを

e = y / (k + r)

により演算し、これらk, r, eによりキーデータおよび連想データのキーデータ領域および連想データ領域への読み/書き制御を行なう、

ことを特徴とする付記2記載のルーチング装置。

(付記8) 前記ルーチングデータ発生部は、

前記キーデータ幅k、連想データ幅r、エントリ数eを保持するレジスタ、

k, r, eによりキーデータおよび連想データの読み/書き制御を行なうアドレスデコーダ、

を備えたことを特徴とする付記7記載のルーチング装置。

# [0053]

(付記9) 前記主制御部のルーチングデータ発生部は、更に、

前記要求された宛先アドレスに応じたキーデータと同一のキーデータ、あるいは、該宛先アドレスに応じたキーデータの非マスク部分と同一のキーデータがキーデータ記憶部に複数エントリされているとき、そのエントリ数、エントリキーデータを保持する保持部、

これらエントリ数、エントリキーデータを外部のプロセッサに通知する手段、 を備えたことを特徴とする付記2記載のルーチング装置。

以上、本発明を実施例により説明したが、本発明は請求の範囲に記載した本発明 の主旨に従い種々の変形が可能であり、本発明はこれらを排除するものではない

# [0054]

#### 【発明の効果】

以上本発明によれば、従来、個々の回線カードと主制御部の両方に配置していたCAM(ルーチングデータ発生部)を主制御部側に集約してルーチングテーブル

を一元管理するように構成したから、システム全体で使用しているCAMの個数 を削減でき、コストダウンと実装効率を向上することができる。

又、本発明によれば、CAMを主制御部にのみ持たせるだけでよいため、システム立ち上げの際、主制御部のメインプロセッサから回線カードにルーチングテーブルを転送する必要がなく、電源投入時やリカバリー時におけるシステム立ち上げ時間を減少することができる。

# [0055]

又、本発明によれば、主制御部は、回線インタフェース部から回線識別子付きのルーチングデータ要求があったとき、回線速度に応じたCAMからルーチングデータを求めて要求元の回線インタフェース部に送出するように構成したから、速度の異なるCAMを回線速度毎に使い分けることが可能となり、安価で低速のCAMを使用でき、しかも、回線カードに種々の速度の回線を収容することが可能となり、回線カードの回線収容効率を向上できる。この結果、ルーチング装置のコストダウンを図ることができる。

又、本発明によれば、主制御部を二重化し、運用中の主制御部はCAMの記憶内容(ルーチングテーブル)を更新するとき、スタンバイ中の主制御部の各CAMのルーチングテーブルも更新し、運用中の主制御部側に障害が発生したとき、スタンバイ中の制御部は新たに運用中制御部としてルーチング制御を継続するように構成したから、CAMをメインプロセッサへ集約した場合の障害発生時の信頼性を向上させることができる。

#### [0056]

又、本発明によれば、連想メモリ部とキーデータ記憶部を1つのメモリアレイで構成し、該メモリアレイの連続する2つの領域をそれぞれ連想メモリ部、キーデータ記憶部とし、メモリアクセス部はメモリアレイの1バイトセルの総数 y、キーデータ幅 k、連想データ幅 r より自動的にメモリアレイに登録可能なキーデータおよび連想データの数(エントリ数)eを求め、これら y, k, r, eに基づいてキーデータおよび連想データのメモリアレイへの読み/書き制御を行なう。このようにすれば、CAM周辺回路の設計変更をしなくても y, k, rをプログラマブルに変更するだけで連想データやキーデータのビット幅を可変制御する

ことができる。

又、本発明によれば、主制御部のルーチングデータ発生部にマルチプルヒットしたエントリ数(ヒット数)、エントリキーデータの管理を行なわせるようにしたから、マルチプルヒット時の処理をCAM LSI内部にて実現でき、メインプロセッサの処理を少なくして負荷を軽減することができる。

# 【図面の簡単な説明】

【図1】

本発明におけるシステム構成図である。

【図2】

CAM検索最低時間を示す図表である。

【図3】

連想データを取得するためのCAM-パケットプロセッサ間の動作処理フローである。

【図4】

CAMーパケットプロセッサ間の送受信データフォーマットである。

【図5】

CAMーパケットプロセッサ間の送受信タイムチャートである。

【図6】

回線カードにおける複数異種回線の混在搭載説明図である。

【図7】

CAM周辺の構成図である。

【図8】

CAMアクセスのタイムチャートである。

【図9】

CAMの内部構成図である。

【図10】

メモリアレイと周辺回路の構成図である。

【図11】

RAMセル幅、キーデータ幅、連想データ幅、エントリ数の関係図表である。

# 【図12】

CAMーメインプロセッサMPU間のデータの流れ説明図である。

【図13】

CAMーパケットプロセッサ間のデータの流れ説明図である。

【図14】

障害時のCAMーパケットプロセッサ間のデータの流れ説明図である。

【図15】

従来のルータの概略構成図である。

【図16】

回線カードの構成図である。

【図17】

CAM検索の流れ図である。

【図18】

従来のルータ装置の詳細な構成図である。

【図19】

従来のルータ装置のパケットの流れ説明図である。

【図20】

CAM LSIの内部構造説明図である。

【符号の説明】

- 11、11'・・主制御部
- $11e_1 \sim 11en \cdot \cdot CAM$
- 12・・スイッチ部
- 13<sub>1</sub>~13n·・回線カード
- 13a・・パケットプロセッサ

【書類名】

図面

【図1】

#### 本発明におけるシステム構成図



【図2】

# CAM検索最低時間を示す図表

(A)

# OC-12C PPP packet 送信

| Items                               | Value |  | IP data<br>変動分n | Total転送<br>時間(μS) |
|-------------------------------------|-------|--|-----------------|-------------------|
| OC-12C転送時間(ns)                      | 1.6   |  | 1               | 0.36              |
| PPP+IP header固定分(byte)              | 27    |  | 2               | 0.37              |
| IP data変動分(byte)                    | n     |  | 3               | 0.39              |
|                                     |       |  | 4               | 0.40              |
| Total転送時間=(n+PPP+ip固定分)) * OC-12C転送 |       |  | ~               | ~                 |
|                                     |       |  | 10              | 0.48              |
|                                     |       |  | ~               | ~                 |
| <u> </u>                            |       |  | 64              | 1.17              |
|                                     |       |  | <b>~</b>        | ~                 |
|                                     |       |  | 128             | 1.99              |
|                                     |       |  | <b>&gt;</b>     | ~                 |
|                                     |       |  | 1024            | 13.52             |
|                                     |       |  | <b>\</b>        | · ~               |
|                                     |       |  | 1500            | 19.64             |

(B)

# OC-192C PPP packet 送信

|   | Items                   | Value    |      | IP data<br>変動分 n | Total転送<br>時間(μS) |
|---|-------------------------|----------|------|------------------|-------------------|
|   | OC-192C転送時間(ns)         | 0.1      |      | 1                | 0.02              |
|   | PPP+IP header固定分(byte)  | 27       |      | 2                | 0.02              |
| L | IP data変動分(byte)        | n        |      | 3                | 0.02              |
|   |                         |          |      | 4                | 0.02              |
|   | Total転送時間=(n+PPP+ip固定分) | )*0C-192 | ?C転送 | <b>~</b>         | ~                 |
|   |                         |          |      | 10               | 0.03              |
|   |                         |          |      | <b>~</b>         | ~                 |
|   |                         |          |      | 64               | 0.07              |
| L |                         |          |      | <b>~</b>         | <b>~</b>          |
|   |                         | •        |      | 128              | 0.12              |
|   |                         |          |      | <b>~</b>         | ~                 |
|   |                         |          |      | 1024             | 0.84              |
|   |                         |          |      | ~                | ~                 |
|   |                         |          |      | 1500             | 1.23              |

# 【図3】

連想データを取得するためのCAM-packet processor間の動作処理フロー



3

【図4】

### CAM-packet processor間送受信data format



【図5】



【図6】

# 回線CARDにおける複数異種回線の混在搭載



【図7】

### CAM周辺の構成図



【図8】

# CAMアクセスのタイムチャート



【図9】

#### CAMの内部構成図



### 【図10】

#### メモリアレイと周辺回路構成



【図11】

# RAM Cell 幅、キーデータ幅:連想データ幅、エントリ数の関係図表

| RAM cell 幅(byte) |   | 1     | 1      |
|------------------|---|-------|--------|
| RAM cell word数   | у | 1,000 | 16,384 |
| Key data 幅(byte) | k | 4     | 16     |
| 連想data幅(byte)    | r | 2     | 2      |
| entry数total      |   | ţ     | 1      |
| e=y/(k+r)        | = | 167   | 910    |

# 【図12】

#### CAM-MPU間のdataの流れ



# 【図13】

#### CAM-packet processor 間の data の流れ



回線(OC-xx, Ethernet)

# 【図14】

# 障害時のCAM-packet processor 間の data の流れ



14

【図15】

### 従来のルータの概略構成図



【図16】

#### 回線Cardの構成



# 【図17】

### CAM検索の流れ



【図18】

#### 従来のRouter装置の詳細な構成図



【図19】

従来ルーター装置の Packet の流れ



【図20】

### CAM LSI の内部構造



【書類名】 要約書

【要約】

【課題】 CAMの個数を削減してルーチング装置のコストダウンと実装効率を 高める。

【選択図】 図1

#### 特2000-295841

### 認定・付加情報

特許出願の番号 特願2000-295841

受付番号 50001253146

書類名特許願

担当官 字留間 久雄 7277

作成日 平成12年10月 2日

<認定情報・付加情報>

【特許出願人】

【識別番号】 000005223

【住所又は居所】 神奈川県川崎市中原区上小田中4丁目1番1号

【氏名又は名称】 富士通株式会社

【代理人】 申請人

【識別番号】 100084711

【住所又は居所】 千葉県千葉市花見川区幕張本郷1丁目14番10

号 幸栄パレス202 齋藤特許事務所

【氏名又は名称】 斉藤 千幹

#### 出願人履歴情報

識別番号

[000005223]

1. 変更年月日

1996年 3月26日

[変更理由]

住所変更

住 所

神奈川県川崎市中原区上小田中4丁目1番1号

氏 名

富士通株式会社